import Vue from 'vue'
import App from './App.vue'
// import App from './Communication.vue'
// 三级联动组件--全局组件
import TypeNav from '@/components/TypeNav'
// 轮播图
import Carsousel from '@/components/Carousel'
// 分页器
import Pagination from '@/components/Pagination'

import { Button, MessageBox } from 'element-ui';
// 第一个参数：全局组件的名字 第二个参数：哪一个组件
Vue.component(TypeNav.name, TypeNav)
Vue.component(Carsousel.name, Carsousel)
Vue.component(Pagination.name, Pagination)
// 注册全局组件
Vue.component(Button.name, Button)
// ElementUI注册组件的时候，还有一种写法，挂在原型上
Vue.prototype.$msgbox = MessageBox;
Vue.prototype.$alert = MessageBox.alert;


// 引入路由
import router from '@/router';
// 引入仓库
import store from '@/store'
// 引入mockServer.js文件---mock数据
import '@/mock/mockServe'
// 引入swiper样式
import "swiper/css/swiper.css"
// 统一接口api文件里面的全部请求函数 统一引入
import * as API from '@/api'
import atm from '@/assets/aoteman.gif'
// 引入插件
import VueLazyload from 'vue-lazyload'
// 注册插件
Vue.use(VueLazyload, {
  // 懒加载默认图片
  loading: atm,
})
// 引入自定义插件
import myPlugins from "@/plugins/myPlugins";
Vue.use(myPlugins, {
  name: 'upper'
})
// 引入表单检验插件
import "@/plugins/validate"

new Vue({
  render: h => h(App),
  // 全局事件总线$bus配置
  beforeCreate() {
    Vue.prototype.$bus = this
    Vue.prototype.$API = API
  },
  // 注册路由：底下的写法KV一致省略V【router小写】
  // 注册路由信息：当这里书写router的时候，组件身上都拥有$route,$router属性
  router,
  // 注册仓库：组件实例的身上会多个一个属性$store属性
  store
}).$mount('#app')
